<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      * {
        margin: 0;
        padding: 0;
        box-sizing: border-box;
        font-size: 18px;
      }
      #app {
        padding: 10px 20px;
      }
      .query {
        margin: 10px 0;
      }
      .box {
        display: flex;
      }
      textarea {
        width: 300px;
        height: 160px;
        font-size: 18px;
        border: 1px solid #dedede;
        outline: none;
        resize: none;
        padding: 10px;
      }
      textarea:hover {
        border: 1px solid #1589f5;
      }
      .transbox {
        width: 300px;
        height: 160px;
        background-color: #f0f0f0;
        padding: 10px;
        border: none;
      }
      .tip-box {
        width: 300px;
        height: 25px;
        line-height: 25px;
        display: flex;
      }
      .tip-box span {
        flex: 1;
        text-align: center;
      }
      .query span {
        font-size: 18px;
      }

      .input-wrap {
        position: relative;
      }
      .input-wrap span {
        position: absolute;
        right: 15px;
        bottom: 15px;
        font-size: 12px;
      }
      .input-wrap i {
        font-size: 20px;
        font-style: normal;
      }
    </style>
  </head>
  <body>
    <div id="app">
      <!-- 条件选择框 -->
      <div class="query">
        <span>翻译成的语言：</span>
        <select v-model="obj.lang">
          <option value="italy">意大利</option>
          <option value="english">英语</option>
          <option value="german">德语</option>
        </select>
      </div>

      <!-- 翻译框 -->
      <div class="box">
        <div class="input-wrap">
          <textarea v-model="obj.words"></textarea>
          <span><i>⌨️</i>文档翻译</span>
        </div>
        <div class="output-wrap">
          <div class="transbox">{{ result }}</div>
        </div>
      </div>
    </div>
    <script src="./vue.js"></script>
    <script src="./axios.js"></script>
    <script>
      // 接口地址：https://applet-base-api-t.itheima.net/api/translate
      // 请求方式：get
      // 请求参数：
      // （1）words：需要被翻译的文本（必传）
      // （2）lang： 需要被翻译成的语言（可选）默认值-意大利
      // -----------------------------------------------

      const app = new Vue({
        el: '#app',
        data: {
          result: '', // 翻译结果
          // words: '',
          obj: {
            words: '苹果',
            lang: 'italy',
          },
        },
        // 具体讲解：(1) watch语法 (2) 具体业务实现
        // 1. 监听输入框的变化
        // 2. 发送请求
        // 3. 将请求响应结果显示到右侧面板中

        watch: {
          // words(newValue, oldValue) {
          //   console.log(newValue, oldValue);
          // },
          // 'obj.words'(newValue, oldValue) {
          //   // console.log(newValue, oldValue);

          //   // this ==> app Vue实例

          //   axios({
          //     method: 'get',
          //     url: 'https://applet-base-api-t.itheima.net/api/translate',
          //     params: {
          //       words: newValue,
          //     }, // 查询参数
          //     // data: {} // 请求体参数
          //   }).then(res => {
          //     // console.log(res, 'res');
          //     this.result = res.data.data;
          //   });
          // },

          obj: {
            deep: true, // 开启深度侦听
            immediate: true, // 进入页面时，立即执行
            handler(params) {
              // 下次进来时，先清除延时器(timerId)
              clearTimeout(this.timerId);
              // 再开启一个新的延时器
              this.timerId = setTimeout(() => {
                // console.log('侦听到了。。。。');
                axios({
                  method: 'get',
                  url: 'https://applet-base-api-t.itheima.net/api/translate',
                  // params: {
                  //   words: newValue.words,
                  //   lang: newValue.lang
                  // },
                  // params: newValue,
                  // params: params
                  params,
                }).then(res => {
                  // console.log(res, 'res');
                  this.result = res.data.data;
                });
              }, 300);
            },
          },
        },
      });
    </script>
  </body>
</html>
